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© Datenverarbeitungsanlage mit virtueller Speicheradressierung und schlusselgesteuertem 
Speicherzugriff. 



© Mit der AdreBumsetzungseinheit (ACU) des Pro- 
zessors (PIU) gekoppelte eigenstandige Schlussel- 
speichersteuereinheit (KMU) mit einem durch reale 
Speicheradressen ansteuerbaren Schlusselspeicher 
(KM), der Eintrage (KEY) fUr jeden im Arbeitsspei- 
cher gesondert geschutzten Datenabschnitt, z.B. Sei- 
te, enthalt. Jeder Eintrag besteht aus dem Speicher- 
schlussel (ACC) und drei weiteren Steuerbits (F, R 
und C.) von denen die letzteren auch der Verwaltung 
dienen. Ansteuerung von AdreBumsetzungseinheit 
(ACU) und Prozessor (PIU) Ober gemeinsame urn- 
schaltbare Eingabeschnittstelle (KMIA), wahrend die 
Ein-/Ausgabeprozessoren (IOP) uber eine gesonder- 



te Schnittstelle angekoppelt sind. Die SchlGsselspei- 
chersteuereinheit (KMU) arbeitet befehlsgesteuert. 
Sie wird bei jeder Speicheranforderung des Prozes- 
sors (PIU) im Rahmen der AdreBumsetzung von der 
AdreBumsetzungseinheit (ACU) angesteuert, wenn 
die Verwaltungsbits zu andern sind Oder noch kein 
Eintrag im AdreBumsetzungspuffer (TLB) vorliegt. 
Kennzeichnung von Eintragen im AdreBumsetzungs- 
puffer (TLB) in einem zum Schlussselspeicher paral- 
lel adressierbaren Speicher (KIAT) gleicher Tiefe 
verhindert unndtige Oberprufungen des AdreBumset- 
zungspuffers (TLB), wenn Eintrage zu ioschen sind. 



CO 



LU 



Rank Xerox (UK) Business Services 

<3. 10/3.09/3.3.4) 

BNSDOCID <EP__0600112A1^L> ■ 



BP 0 600 112 A1 



A!? 9 

<: 



mu 



KHU 



mil 



Ml 



Cll 



j fll-AIF 

1 O o 

-f-W — o 



HI Ml j Pill 



I0P 



Ml CHI UC INI /I 



AVS1 



. W-Cll 



IMl-q 
mil 



III! 



t>mV»l 



AVS2 



II 

i'»iiIIiL 



E 



E5U 



L_i 



ACU 



i ij i i 



UC.f.l.t 



-tkt 



Fin"' | 



[ IM : iCC/F 

r — |-°r$w:«c 



FI6 I 



Ill:Ut/f in ii j 



1 m \ : ; 

TT ! ill I 



I 

1*1-/1 II 



BNSDOCID:<EP 0600112A1J_> 



1 



EP 0 600 112 A1 



2 



Die Erfindung betrifft eine Datenverarbeitungs- 
anlage entsprechend dem Oberbegriff des Patent- 
anspruches 1. 

Die Verknupfung der Adreflumsetzung mit der 
Schlusselverwaltung fur den Speicherschutz ist all- 
gemein bekannt -man siehe z.B. "Computer Archi- 
tecture And Parallel Processing" von Kai Hwank 
und Faye A. Briggs, McGraw-Hill Book Company, 
New York, 1984, S. 65 bis 79, Oder Siemens 
Druckschrift D1 5/51 04 -04, S. 6-1 bis 6-7. 

Auch ist es bekannt, die Speicherschlussel 
nicht in die einzelnen Ubersetzungstabellen aufzu- 
nehmen, sondern in einem gesonderten Speicher- 
teil des Arbeitsspeichers als Schlusselspeicher mit 
der reallen Seitenadresse ansteuerbar zusammen- 
gefaSt zu speichern -man siehe z.B. EP-0 106 600- 
B1. Die Uberprufung der Zugriffsberechtigung er- 
folgt dabei im Rahmen der Speicheransteuerung 
vor dem freizugebenden, eigentlichen Speicherzug- 
riff auf die Daten im Arbeitsspeicher. Auch diese 
Losung laBt sich mit einem AdreBumsetzungspuf- 
fer, dessen Eintrage zusatzlich den Speicher- 
schlussel enthalten, koppeln mit dem Vorteil, daB 
Arbeitsspeicherzugriffe unmittelbar ohne vorherige 
Prufung anhand des Eintrags im Schlusselspeicher 
freigegeben werden konnen. 

Den eigentlichen Schlusselwerten sind im all- 
gemeinen gesonderte, der Verwaltung dienende 
Steuerbits zugeordnet, die daruber Auskunft geben, 
ob auf eine zugehorige Datenseite im Arbeitsspei- 
cher zugegriffen worden ist und ob der Zugriff 
schreibend und damit datenverandernd war. Diese 
Steuerbits mussen daher bei jedem Speicherzugriff 
angesteuert und gegebenenfalls geandert werden, 
so dafi es zweckmaBig ist, bei Verwendung eines 
AdreBumsetzungspuffers auch diese Steuerbits 
dort zu fuhren. 

Dabei ist jedoch sicherzustellen, daB bei der 
Loschung eines Eintrags im AdreBumsetzungspuf- 
fer die zugehorigen Steuerbits in den Schlussel- 
speicher ubertragen werden. Bei im AdreBumset- 
zungspuffer vorliegenden Eintragen konnen daher 
Zugriffe zum Schlusselspeicher ebenfalls entfallen. 
Sie sind weiterhin nur erforderllch, wenn infolge 
Fehlens eines Eintrags im AdreBumsetzungspuffer 
eine AdreBubersetzung erforderlich wird. Von 
Nachteil dabei ist jedoch, daB die Eintrage fur die 
Verwaltungsbits im Schlusselspeicher und im 
AdreBumsetzungspuffer nicht mehr konsistent sind, 
so daB Direktzugriffe eines Ein-/Ausgabeprozessors 
zum Arbeitspeicher und Anderungen der Schlus- 
seleintrSge im Schlusselspeicher bei notwendig 
werdendem Seitenwechsel besondere Steuerungs- 
mafinahmen erfordern. 

Aufgabe der Erfindung ist es daher, eine Da- 
tenverarbeitungsanlage entsprechend dem Oberbe- 
griff des Patentanspruches 1 so zu gestalten, daB 
die mit der Verwaltung der Speicherschlussel ver- 
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bundenen Probleme in einfacher und die Datenver- 
arbeitungsanlage weniger belastender Weise sowie 
mit verhaltnismafiig geringem Aufwand gelost wer- 
den. 

5 Diese Aufgabe wird durch die kennzeichnen- 

den Merkmale des Patentanspruches 1 gelost. Da- 
nach sind alle Schlussel zu den im Arbeitsspeicher 
jeweils befindlichen Speicherabschnitten oder -sei- 
ten ebenfalls in einem Speicher als Schlusselspei- 

io cher zusammengefaBt. Dieser Schlusselspeicher ist 
aber nicht mehr Bestandteil des Arbeitsspeichers, 
sondern einer eigenstandigen Schlusselspeicher- 
steuereinheit zugeordnet, die unabhangig vom Ar- 
beitsspeicher uber jeweils gemeinsame Schnittstel- 

75 len wahlweise sowohl mit dem steuernden Prozes- 
sor als auch mit der AdreBumsetzungseinheit kop- 
pelbar ist. Alle vom Betriebssystem uber den steu- 
ernden Prozessor veranlaBten Anderungen im 
Schlusselspeicher und alle im Rahmen der uber 

20 die AdreBumsetzungseinheit geleiteten normalen 
Speicherzugriffe notwendig werdenden Anderun- 
gen konnen daher in einheitlicher Weise befehlsge- 
steuert ohne zusatzliche Belastung des Arbeits- 
speichersystems ausgefuhrt werden. 

25 In analoger Weise zur Ansteuerung uber die 

Eingabeschnittstelle konnen gemaB Patentan- 
spruch 3 auch Ein-/Ausgabeprozessoren uber indi- 
viduelle Schnittstellen an die Schlusselspeicher- 
steuereinheit angeschlossen sein, wobei eine Vor- 

30 rangschaltung fur alle Ansteuerschnittstellen den 
Zugriff zum Schlusselspeicher regelt. Die fur Riick- 
signale notwendige zweite Schnittstelle braucht in 
diesem Falle nur ein Prufsignal "Zugriff erlaubt" 
bzw. "Zugriff nicht erlaubt" zuruckzuleiten und 

35 kann entsprechend schmal gestaltet werden. 

GemaB Anspruch 4 ist dem Schlusselspeicher 
ein weiterer Speicher parallel geschaltet, wobei bei- 
de Speicher parallel ansteuerbar sind. In diesem 
weiteren Speicher wird jeder im AdreBumsetzungs- 

40 puffer enthaltene Eintrag durch ein Steuerbit ge- 
kennzeichnet, so daB bei jeder Anderung eines 
Schlussels im Schlusselspeicher parallel gepruft 
werden kann, ob ein zwangslaufig zu loschender 
Eintrag im AdreBumsetzungspuffer vorliegt. Dieser 

45 als Filter wirkende weitere Speicher verhindert da- 
mit, daB bei jeder Schlusselanderung der gesamte 
AdreBumsetzungspuffer auf entsprechende Eintra- 
ge uberpruft werden muB. 

Einzelheiten der Erfindung seien nachfolgend 

so anhand eines in der Zeichnung dargestellten Aus- 
fuhrungsbeispieles nSher erlSutert. Im einzelnen 
zeigen 

Figur 1 ein Blockschaltbild der SchlOsselspei- 
chersteuereinheit gemaB der Erfindung mit den 
55 zugehorigen Schnittstellen, 

Figur 2 ein FluBdiagramm zur Erlauterung des 
Steuerungsablaufs bei einem an die AdreBum- 
setzungseinheit gerichteten Speicherzugriff, 

3 
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Figur 3 ein FluBdiagramm zu ErISuterung des 
Steuerungsablaufs in der SchlOsselspeicher- 
steuereinheit, abhangig vom jeweils auszufuh- 
renden Befehl und 

Figur 4A und 4B Flufi diagram me fur die Ausfuh- 
rung einzelner Befehle in Erganzung des FluB- 
diagramms von Figur 3. 

Beim Blockschaltbild von Figur 1 bildet der 
mittiere Teil die Schlusselspeichersteuereinheit 
KMU, die im oberen Teil uber die Eingabeschnitt- 
stelle KMIA und im unteren Teil uber die Ausgabe- 
schnittstelle KMIB mit der AdreBumsetzungseinheit 
ACU und uber diese auch mit dem steuernden 
Prozessor PIU verbunden ist, wahrend der rechte 
Teil den Anschlufi von und zum Ein-/Ausgabepro- 
zessor IOP wiedergibt. Bei mehreren Eiiv/Ausgabe- 
prozessoren konnten diese einzeln nacheinander 
uber eine gesonderte Auswahlsteuerschaltung mit 
dem gemeinsamen AnschluB zur Schlusselspei- 
chersteuereinheit KMU verbunden werden. 

Die Ansteuerung sowohl seitens der AdreBum- 
setzungseinheit ACU und des steuernden Prozes- 
sors PIU als auch des Ein-/Ausgabeprozessors IOP 
erfolgt in einheitlicher Weise durch Bereitstellung 
der reaien Speicherseitenadresse PAD und des 
auszufuhrenden Befehls CMD sowie des zugehori- 
gen Schlusselspeichereintrags KEY bei Anforderun- 
gen vom steuernden Prozessor PIU bzw. des Zug- 
riffsschlussels ACC bei Anforderungen vom Ein- 
/Ausgabeprozessor IOP. Der Eingabeschnittstelle 
KMIA sind Auswahlschalter AWS-ANF zur Durch- 
schaltung entweder der Anforderung PIU-ANF des 
steuernden Prozessors PIU Oder der Anforderun- 
gen AT-ANF der AdreBumsetzungseinheit ACU vor- 
geschaltet. Eingestellt werden diese Auswahlschal- 
ter AWS-ANF durch das Steuersignal AT der 
AdreBumsetzungseinheit ACU in der Weise, dafi im 
Ruhezustand die Anforderungen des steuernden 
Prozessors PIU durchgeschaltet werden, wahrend 
bei an die AdreBumsetzungseinheit ACU gerichte- 
ten Speicheranforderungen des steuernden Prozes- 
sors die AdreBumsetzungseinheit auf die Durch- 
schaltung eigener Anforderungen umsteuert. 

Die Schnittstellenleitungen sind jeweils mit ent- 
sprechenden Ubernahmeregistern CMD- A, PAD-A, 
KEY-A bzw. CMD-B. PAD-B, ACC-B, der Schlus- 
selspeichersteuereinheit KMU verbunden, wobei 
die Obernahme beispielsweise durch die Anforde- 
rungen begleitende Anforderungssignale KMRO 
bzw. KMR-IO gesteuert wird. Eine Vorrangsschal- 
tung PRIO in der Steuerung KM-CTL uberwacht 
das Vorliegen von Anforderungen und w§hlt die 
jeweils vorrangige Anforderung aus, indem die den 
Ubernahmeregistern nachgeschalteten Auswahl- 
schalter AWS1 und AWS2 entsprechend eingestellt 
werden. Damit steht der jeweilige Befehl CMD ei- 
ner Anforderung fur die Auswertung durch die 
Steuereinrichtung KM-CTL zur Verfugung und 



ebenso die jeweils zugehorige reale Seitenadresse 
PAD fur die Ansteuerung des SchlOsselspeichers 
KM. 

Dieser Schlusselspeicher KM enthalt fur jeden 
5 im Arbeitsspeicher der Datenverarbeitungsanlage 
geschutzten Speicherabschnitt, z.B. in Form einer 
Speicherseite von jeweils 4 KByte, einen Eintrag, 
der aus dem eigentlichen Speicherschlussel ACC, 
einem Steuerbit F als mogliche Holsperre und zwei 

to Verwaltungsbits R und C besteht, wobei das Bit R 
bei jedem Speicherzugriff gesetzt wird und das 
gesetzte Bit C einen schreibenden Speicherzugriff 
kennzeichnet. Mit einem 256 KByte tiefen Schlus- 
selspeicher kann also z.B. ein Arbeitsspeicher mit 

75 1 GByte Speicherkapazitat abgedeckt werden. 

Der Schlusselspeicher KM ist mit einem Lese- 
register KM-R gekoppelt, dessen Ausgang einer- 
seits mit der Ausgabeschnittstelle KMIB und ande- 
rerseits mit einem Ruckkopplungszweig zum Aus- 

20 wahlschaiter AWS3 zur Anderung der Steuerbits R 
und C fur einen eingetragenen Schlussel ACC/F im 
Schlusselspeicher KM verbunden ist. AuBerdem 
kann der ins Leseregister KM-R ubernommene 
Speicherschlussel bei Anforderung durch den Ein- 

25 /Ausgabeprozessor IOP einem Vergleicher VG1 zu- 
gefuhrt werden, der den im Obernahmeregister 
ACC-B verfugbaren Zugriffsschlussel mit dem ge- 
lesenen Speicherschlussel vergleicht und abhangig 
vom Prufergebnis die Steuerung KM-CTL veranlaBt 

30 ein entsprechendes Signal OK an den Ein-/Ausga- 
beprozessor IOP zu liefern, das durch ein Begleitsi- 
gnal KMR-11 zur Auswertung freigegeben wird. 

Uber die Ausgabeschnittstelle KMIB kann ein 
aus dem Schlusselspeicher KM gelesener Schlus- 

35 seleintrag KEY oder Teile desselben in Verbindung 
mit einem Ruckmeldesignal KMR1 der Steuerein- 
richtung KM-CTL einerseits dem steuernden Pro- 
zessor PIU und andererseits der AdreBumsetzungs- 
einheit ACU ubergeben werden. Zustandiger Emp- 

40 fanger ist dabei immer die Einheit, die die zugeho- 
rige Anforderung ausgelost hat. War die anfordern- 
de Einheit die AdreBumsetzungseinheit ACU, dann 
wird der gelesene Speicherschlussel KM:ACC/F 
gegebenenfalls fur den Eintrag in den AdreBumset- 

45 zungspuffer TLB und fur den Vergleich mit dem 
vom steuernden Prozessor PIU zur Verfugung ge- 
stellten Zugriffsschlussel PSW:ACC benotigt. Dies 
ist im unteren Teil der Figur angedeutet, der in 
schematischer Darstellung den AdreBumsetzungs- 

50 puffer TLB der AdreBumsetzungseinheit ACU mit 
zugehoriger Steuerung ST zeigt Die Eintrage im 
AdreBumsetzungspuffer TLB bestehen in bekannter 
Weise aus von der Obrigen AdreBumsetzungs- 
steuerung gelieferten Paaren von virtueller Adresse 

55 VAD und zugehoriger realer Adresse PAD, die 
durch die zugehorigen Speicherschlussel ACC/F 
und das Steuerbit C erganzt sind, wahrend die 
Funktion des Steuerbits R vom jeweiligen Gultig- 
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keitsbit Ubernommen wird. 

Bei einem bereits im AdreBumsetzungspuffer 
TLB vorhandenen Eintrag kann abhangig von der 
virtuellen Adresse VAD neben der zugehorigen 
realen Adresse PAD unmittelbar auch der zugeho- 
rige Speicherschlussel TLB:ACC ermittelt und fur 
einen Vergleich mit dem vom steuernden Prozes- 
sor PIU gelieferten Zugriffsschlussel PSW:ACC/F 
durch den Vergleicher VG2 herangezogen werden, 
so dafi ein Speicherzugriff mit der ermittelten rea- 
len Adresse PAD unmittelbar freigegeben oder ver- 
hindert werden kann. Ergibt dagegcn die Oberpru- 
fung des AdreBumsetzungspuffers TLB, daB noch 
kein Eintrag vorliegt, dann kann die Oberprufung 
der Zugriffsberechtigung unmittelbar nach der dann 
notwendigen AdreBubersetzung anhand des aus 
dem Schlusselspeicher KM gelesenen Speicher- 
schlusseis KM:ACC/F vorgenommen werden. 

Parallel zum Schlusselspeicher KM tst ein wei- 
terer Speicher KIAT gleicher Tiefe vorgesehen, der 
mit der jeweils freigegebenen realen Adresse PAD 
parallel zum Schlusselspeicher angesteuert wird. 
Die Eintrage in diesem Speicher KIAT bestehen 
jeweils aus einem Bit, das im gesetzten Zustand 
einen zugehorigen Eintrag im AdreBumsetzungs- 
puffer TLB anzeigt. Bei einer Anderung des 
Schlussel im Schlusselspeicher KM mfolge des 
Austausches einer Speicherseite im Arbeitsspei- 
cher kann auf diese Weise unmittelbar erkannt 
werden, ob durch die Schlusselanoerung ungultig 
gewordene Eintrage im Adrefiumsetzungs puffer 
TLB zu loschen sind oder nicht. Dadurch entfallen 
in einfacher Weise unnotige, das System belasten- 
de Uberprufungen des AdreBumsetzungspuflers auf 
zu loschende Eintrage. 

Die Schlusselspeichersteueretnheit KMU arbei- 
tet befehlsgesteuert durch die mit der jeweiligen 
Anforderung angelieferten Befehle CMD. Dabei 
kann abhangig von der anfordernden Quelle zwi- 
schen drei Gruppen von Befehlen unterschieden 
werden, namlich 

a) Befehle der AdreBumsetzungsemheit ACU zur 
Anderung der Steuerbits im Schlusselspeicher 
KM und im Speicher KIAT im Rahmen von 
Speicherzugriffsanforderungen durch oen steu- 
erdnen Prozessor PIU und gegebenenfalls zum 
Auswerten des Speicherschlusseis bei tehlen- 
den Eintragen im AdreBumsetzungspuffer TLB, 

b) Befehle des Ein-/Ausgabeprozessors IOP zur 
Prufung der Speicherzugriffsberechtigung an- 
hand des im Schlusselspeicher KM eingetrage- 
nen SpeicherschlUssels mit entsprechender An- 
derung der der Verwaltung dienenden Steuerbits 
R und C und 

c) vom Betriebssystem veranlafite Belehle des 
steuernden Prozessors PIU in Verbindung mit 
der Bereitstellung und der Auslagerung von 
Speicherseiten im Arbeitsspeicher. 
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Die Einbettung der Befehle der AdreBumset- 
zungseinhelt ACU in den Qblichen AdreBUberset- 
zungsvorgang im Rahmen einer Speicheranforde- 
rung ist aus dem FluBdiagramm von Figur 2 er- 
5 sichtlich. Anhand der mit der Speicheranforderung 
verbundenfcn virtuellen Speicheradresse VAD wird 
zunachst der AdreBumsetzungspuffer TLB auf Vor- 
liegen einer ubersetzten realen Adresse PAD zu 
der virtuellen Adresse uberpruft. Liegt noch kein 

70 Eintrag vor, wird die AdreBubersetzung angefordert 
und in bekannter Weise durchgefuhrt. Unabhangig 
davon, ob es sich beim gewunschten Speicherzug- 
riff um einen Lese- oder Schreibzugriff handelt, 
wird anhand der ubersetzten Adresse PAD der 

75 zugehorige Speicherschlussel aus dem Schlussel- 
speicher KM angefordert, was zu den entsprechen- 
den Befehlen READ KEY... zum Lesen des Spei- 
cherschlusseis fuhrt, wobei im Vorgriff bei einer 
Leseanforderung das Steuerbit R gesetzt wird und 

20 bei einer Schreibanforderung beide Steuerbits R 
und C im Schlusselspeicher KM gesetzt werden. 
AuBerdem wird im selben Steuervorgang das Steu- 
erbit im Speicher KIAT bereits gesetzt, da bei 
einem zulassigen Speicherzugriff auch ein Eintrag 

25 im AdreBumsetzungspuffer TLB anzulegen ist. An- 
hand des aus dem Schlusselspeicher KM gelese- 
nen Speicherschlusseis KM:ACC/F wird dann durch 
den Vergleicher VG2 anhand des vom steuernden 
Prozessor PIU gelieferten Zugriffssschlussels 

30 PSW:ACC die Zulassigkeit des Speicherzugriffs 
uberpruft. Ist der Zugriff zulassig, wird ein entspre- 
chender Eintrag im AdreBumsetzungspuffer TLB 
mit dem gelesenen Speicherschlussel ACC/F ange- 
legt, wobei im Falle von Schreibzugriffen auch das 

35 Steuerbit C gesetzt wird. AuBerdem wird der ei- 
gentliche Speicherzugriff veranlaBt. 

Ist dagegen keine AdreBubersetzung moglich 
oder die Zugriffsberechtigung nicht gegeben, wird 
mit INTERRUPT in bekannter Weise in eine Unter- 

40 brechungsroutine ubergeleitet. 

Ist im AdreBumsetzungspuffer TLB bereits ein 
gultiger Eintrag zu der die Speicheranforderung 
begleitenden virtuellen Adresse VAD vorhanden, 
wird die Zugriffsberechtigung unmittelbar anhand 

45 des im AdreBumsetzungspuffer TLB eingetragenen 
Speicherschlusseis TLB:ACC/F uberpruft. Liegt 
eine Schreibanforderung vor, wird aufierdem ge- 
pruft, ob das Steuerbit C im AdreBumsetzungspuf- 
fer bereits gesetzt ist. Ist dies der Fall oder liegt 

50 eine Leseanforderung vor, kann bei gegebener 
Zugriffsberechtigung unmmittelbar der gewunschte 
Speicherzugriff veranlaBt werden. Im anderen Falle 
ist die SchlUsselspeichersteuereinheit KMU mit 
dem Befehl SET R/C anzusteuern und im AdreB- 

55 umsetzungspuffer TLB das Steuerbit C zu setzen. 
Das Mitfuhren des Steuerbits C im AdreBumset- 
zungspuffer erspart somit ein zusatzliches Ansteu- 
ern der Schlusselspeichersteueretnheit KMU. 

5 
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Fgllt dagegen die SchlusselOberprOfung an- 
hand des Eintrags im Adrefiumsetzungsspeicher 
TLB negativ aus, dann muB in die ubliche AdreB- 
iibersetzung entsprechend dem bereits erlauterten 
linken Ablaufzweig des FluBdiagrammes ubergelei- 
tet werden. 

Das FluGdiagramm von Figur 3 zeigt den durch 
Anforderungen an die Schlusselspeichersteuerein- 
heit KMU ausgelosten und von der Steuerung KM- 
CTL durchgefuhrten allgemeinen Steuerungsablauf 
ohne Differenzierung entsprechend den verschie- 
denen Befehlen CMD. Danach werden die ver- 
schiedenen Schnittstellen auf das Vorliegen von 
Anforderungen fortlaufend uberwacht. 1st eine An- 
forderung erkannt, wird bei mehreren gleichzeitigen 
Anforderungen die jeweils bevorrechtigte ausge- 
wahlt und der zugehorige Befehl CMD decodiert 
und ausgefuhrt. 

Beim gewahlten Beispiel sind insgesamt acht 
verschiedene Befehle vorgesehen, namlich die bei 
der Beschreibung des FluBlaufdiagramms von Fi- 
gur 2 bereits angesprochenen Befehle SET R/C, 
READ KEY-SET R und READ KEY-SET R/C von 
der AdreBumsetzungseinheit ACU t die vom Be- 
triebssystem ausgehenden Befehle RRBE, ISKE 
und SSKE sowie die beiden Befehle CHECK KEY... 
vom Ein-/Ausgabeprozessor IOP. 

Die von diesen Befehlen durch die Steuerung 
KM-CTL veranlaBten Steuerungsablauf e sind in Fi- 
gur 4 im einzelnen dargestellt. 

Figur 4A zeigt die Steuerungsablaufe fur die 
drei Befehle der AdreBumsetzungseinheit ACU. In 
alien Fallen wird mit der realen Adresse PAD der 
Schlusselspeicher KM und bei den Befehlen READ 
KEY... auch der Speicher KIAT gelesen. Danach 
werden die Werte fur die zu andernden Speicher- 
stellen eingestellt und als neue Werte zuruckge- 
schrieben. Bei den Befehlen READ KEY.... wird 
auBerdem der gelesene Speicherschlussel an den 
AdreBumsetzungspuffer TLB mit dem Ubergabesi- 
gnal KMR1 weitergeleitet. 

In ahnlicher Weise sind die Steuerungsablaufe 
fur die Befehle CHECK KEY vom Ein-/Ausgabepro- 
zessor IOP gemaB dem rechten Teil von Figur 4B 
gestaltet, wobei nach dem Lesen des Schlussel- 
speichers KM zunachst der Schlusselvergleich 
durchgefuhrt wird und Anderungen der Steuerbits 
im Schlusselspeicher KM nur bei Schlusseluberein- 
stimmung ausgefuhrt werden. Beide Befehlsausfuh- 
rungen enden mit einer Ruckmeldung an den an- 
fordernden Ein-/Ausgabeprozessor IOP, wobei bei 
Schlusselungleichheit die Ruckmeldung unmittelbar 
erfolgt. 

Gegenuber den bereits beschriebenen Befehls- 
ablaufen haben die zu den Befehlen RRBE, ISKE 
und SSKE des Betriebssystems im linken Teil von 
Figur 4B nicht unmittelbar mit einer Speicherzug- 
riffsanforderung zu tun. Mit dem Befehl RRBE fragt 



das Betriebssystem die Eintrage des Schlussel- 
speichers KM periodisch der Reihe nach ab, um zu 
ermitteln, zu welcher Speicherseite langere Zeit 
nicht zugegriffen worden ist. Mit jeder Uberprufung 
5 werden daher die gelesenen Steuerbits R und C an 
den steuernden Prozessor PIU ubertragen und ein 
gesetztes Steuerbit R wird jeweils zuruckgesetzt. 
Das Betriebssystem ermittelt auf diese Weise eine 
Entscheidungsbasis fur den Ersetzungsalgorithmus, 

io wenn im Arbeitsspeicher Speicherplatz fur eine 
neue Speicherseite benotigt wird. 

Bevor aber eine neue Seite im Arbeitsspeicher 
ausgetauscht werden kann, muB jedoch gepruft 
werden, ob die Daten der aiten Seite entsprechend 

15 der Kennezeichnung C = 1 verandert worden sind. 
Bei unveranderter Seite kann diese unmittelbar 
uberschrieben werden, wahrend eine im Arbeits- 
speicher geanderte Seite erst ausgelagert werden 
muB. Das Betriebssystem pruft dies mit dem Be- 

20 fehl ISKE, indem der gesamte Eintrag im Schlus- 
selspeicher KM gelesen und an den steuernden 
Prozessor PIU ubertragen wird. 

SchlieBlich wird beim Austausch einer Seite im 
Arbeitsspeicher der zugehorige Schlusseleintrag im 

25 Schlusselspeicher KM ungultig und ist daher durch 
den fur die neue Seite zu ersetzen. Hierzu dient 
der Befehl SSKE, bei dem zunachst anhand der 
Einstellung durch die reale Seitenadresse PAD der 
Speicher KIAT gelesen wird. Ist das gelesene Steu- 

30 erbit nicht gesetzt, wird der vom steuernden Pro- 
zessor PIU mitgeteilte Schlusselspeichereintrag 
einschlieBlich der auf Null gesetzten Steuerbits R 
und C unmittelbar in den Schlusselspeicher KM 
eingetragen. Liegt dagegen im Speicher KIAT eine 

35 Kennzeichnung vor, wird zunachst die im Ubernah- 
meregister PAD-A stehende reale Seitenadresse 
PAD in das Register PAD-BUF ubertragen. An- 
schlieBend wird die Kennzeichnung fur den Spei- 
cher KIAT auf "0" gestellt, bevor die Eintrage in 

40 beiden Speichern erneuert werden und die zwi- 
schengespeicherte reale Seitenadresse PAD an 
den steuernden Prozessor PIU ubergeben wird. 
Das Betriebssystem kann dann anhand der so er- 
mittelten realen Seitenadresse die Uberprufung des 

45 AdreBumsetzungspuffers TLB veranlassen und 
durch Lbschen der betroffenen Eintrage die Ober- 
einstimmung mit dem im Eintrag im Schlusselspei- 
cher KM sichern. 

Beim gezeigten Ausfuhrungsbeispiel gemaB Fi- 

50 gur 1 werden die Eintrage KEY aus dem Schlussel- 
speicher KM und die Adresse PAD aus dem Puff- 
erregister PAD-BUF Ober getrennte Schnittstellen- 
leitungen an den Prozessor PIU Obergeben, wobei 
die Anzahl der Schnittstellenleitungen fur die 

55 Adresse PAD wesentlich groBer ist als die fur den 
Eintrag KEY. Man konnte daher die Anzahl der 
Schnittstellenleitungen auf die fur den Eintrag KEY 
reduzieren, wenn man die Adresse PAD jeweils in 
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Portionen von der LSnge des Eintrags KEY auftei- 
len und diese Portionen nacheinander Ober diesel- 
ben Schnittstellenleitungen ubertragen wurde. 

Patentanspruche 5 

1. Datenverarbeitungsanlage, die mit virtueller 
Speicheradressierung und AdreBumsetzung 
der virtuellen Adressen (VAD) eines Hinter- 
grundspeichers in reale Adressen (PAD) fur io 
einen Arbeitsspeicher (ASP) arbeitet und bei 
der Zugriffe zum Arbeitsspeicher (ASP) uber 
eine AdreBumsetzungseinheit (ACU) mit AdreB- 
umsetzungspuffer (TLB) an Hand virtueller 
Adressen (VAD) erfolgen, wobei im Arbeits- 
speicher (ASP) nicht vorhandene Daten aus 
dem Hintergrundspeicher nachgeladen werden 
und dem zugehorigen Datenabschnitt, z.B. 
Speicherseite. jeweils eine reale Adresse 
(PAD) des im Arbeitsspeicher zur Verfugung 
gestellten Datenabschnittes zugeordnet wird, 
und bei der die Datenabschnitte durch zuge- 
ordnete Speicherschlussel (ACC) gegen unbe- 
rechtigte Zugriffe geschutzt sind, indem die 
den einzelnen zu verarbeitenden Programmen 
oder Programmabschnitten zugeordneten Zug- 
riff sschlussel (PSW:ACC) jeweils mit dem ent- 
sprechenden Speicherschlussel (ACC) vergli- 
chen werden und indem nur bei Ubereinstimm- 
mung beider der Zugriff erlaubt wird, wobei die 
Eintrage im AdreBumsetzungspuffer (TLB) je- 
weils mit dem zugehorigen Speicherschlussel 
(ACC) versehen sind und fur den Vergleich 
verwendet werden, 
dadurch gekennzeichnet, 

- daB die Speicherschlussel (ACC) aller im 
Arbeitsspeicher (ASP) vorhandenen Da- 
tenabschnitte in einem real adressierten 
Schlusselspeicher (KM) zusammengefaBt 
sind, der Bestandteil einer eigenstandi- 
gen Schlusselspeichersteuereinheit 
(KMU) ist, die einerseits uber eine ge- 
meinsame, von der Adrefiumsetzungsein- 
heit (ACU) gesteuerte Eingabeschnittstel- 
le (KMIA) und andererseits uber eine ge- 
meinsame Ausgabeschnittstelle (KMIB) 
jeweils sowohl mit der Adrefiumsetzungs- 
einheit (ACU) als auch mit dem steuern- 
den Prozessor (PIU) verbunden ist, 

- daB bei Speicherzugriffen, gesteuert so 
durch entsprechende Befehle der Adrefi- 
umsetzungseinheit (ACU), EintrSge des 
SchlOsselspeichers (KM) fOr die Eintrage 

im AdreBumsetzungspuffer (TLB) zur 
Verfugung gestellt und dem Speicher- 55 
schlussel (ACC) im Schlusselspeicher 
(KM) zugeordnete Steuerbits (R, C) ab- 
hangig von der jeweiligen Speicherzug- 



riffsart verSndert werden und 
- daB zum Austausch von Datenabschnit- 
ten zwischen dem Hintergrundspeicher 
und dem Arbeitsspeicher (ASP), gesteu- 
ert durch entsprechende Befehle des 
steuernden Prozessors (PIU), die ent- 
sprechenden Schlusseleintrage im 
Schlusselspeicher (KM) uberpruft 
und/oder geandert werden. 



2. Datenverarbeitungsanlage nach Anspruch 1 , 
dadurch gekennzeichnet, 
dafi die Eingabeschnittstelle (KMIA) durch vor- 
geschaltete Umschalter (AWS-ANF) normaler- 

15 weise mit dem steuernden Prozessor (PIU) 

verbunden ist, daB eine Umschaltung der Ein- 
gabeschnittstelle (KMIA) auf die Adrefiumset- 
zungseinheit (ACU) durch diese nur nach einer 
Speicheranforderung durch den steuernden 
20 Prozessor im Rahmen der durchzufuhrenden 

AdreBumsetzung erfolgt und dafi eine neue 
Anforderung von der Schlusselspeicher-Steue- 
reinheit (KMU) jeweils nur entgegengenommen 
wird, wenn eine zuvor angenommene Anforde- 
25 rung erledigt ist, so daB der steuernde Prozes- 

sor (PIU) anhand des von ihm ausgelosten 
Steuervorganges (Speicherzugriff oder Schlus- 
selspeicheransteuerung) erkennen kann. ob an 
der gemeinsamen Ausgabeschnittstelle (KMIB) 
30 anliegende Daten fur ihn bestimmt sind oder 

nicht. 

3. Datenverarbeitungsanlage nach Anspruch 1 
oder 2, 

35 dadurch gekennzeichnet, 

dafi Ein-/Ausgabeprozessoren (IOP) uber eine 
gemeinsame Ansteuerschnittstelle parallel zur 
gemeinsamen Eingabeschnittstelle (KMIA) fur 
den steuernden Prozessor (PIU) und die 
40 Adrefiumsetzungseinheit (ACU) mit der Schlus- 

selspeichersteuereinheit (KMU) verbunden 
sind, daB eine Vorrangschaltung uber die An- 
nahme gleichzeitig vorliegender Anforderungen 
entscheidet und dafi Anforderungen von einem 
45 Ein-/Ausgabeprozessor (IOP) lediglich mit ei- 

nem Signal (OK) "Zugriff erlaubt" bzw. "Zugriff 
nicht erlaubt" beantwortet werden. 



4. Datenverarbeitungsanlage nach einem der An- 
sprtiche 1 bis 3, 

dadurch gekennzeichnet, dafi dem Schlus- 
selspeicher (KM) ein weiterer, real adressierter 
Speicher (KIAT) parallel geschaltet ist, in dem 
die im AdreBumsetzungspuffer (TLB) enthalte- 
nen Eintrage uber Datenabschnitte des Ar- 
beitsspeichers (ASP) durch ein gesondertes 
Steuerbit gekennzeichnet sind, dafi bei Eintrag 
eines neuen Schlussels (ACC) in dem Schlus- 



7 



BNSDOCID- <EP 06001 12A1J_> 



11 EP0 600 112 A1 12 



selspeicher (KM) der zweite Speicher (KIAT) 
auf Vorliegen einer Kennzeichnung zu dem 
geloschten Schlussel (ACC) uberpruft wird und 
da!3 bei Vorliegen einer Kennzeichnung anhand 
der zugehorigen Adresse (PAD) entsprechen- 5 
de Eintrage im AdreBumsetzungspuffer (TLB) 
geloscht werden. 

5. Datenverarbeitungsanlage nach Anspruch 4, 

dadurch gekennzeichnet, io 
da/3 die ermittelte reale Seitenadresse (PAD) 
zunachst an den steuernden Prozcssor (PIU) 
weitergeleitet wird und daB bei einer der Breite 
(1 Byte) eines Eintrags im Schlusselspeicher 
(KM) entsprechenden Breite der Ausgabe- 15 
schnittstelle (KMIB) die Ubergabe der realen 
Seitenadresse (PAD) in entsprechenden Teilen 
nacheinander erfolgt. 

20 
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50 
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